<!--
  -    Copyright (c) 2018-2025, bfcloud All rights reserved.
  -
  - Redistribution and use in source and binary forms, with or without
  - modification, are permitted provided that the following conditions are met:
  -
  - Redistributions of source code must retain the above copyright notice,
  - this list of conditions and the following disclaimer.
  - Redistributions in binary form must reproduce the above copyright
  - notice, this list of conditions and the following disclaimer in the
  - documentation and/or other materials provided with the distribution.
  - Neither the name of the pig4cloud.com developer nor the names of its
  - contributors may be used to endorse or promote products derived from
  - this software without specific prior written permission.
  - Author: bfcloud
  -->

<template>
  <div class="execution">
    <basic-container>
      <avue-crud
        ref="crud"
        :page.sync="page"
        :data="tableData"
        :table-loading="tableLoading"
        :option="tableOption"
        @on-load="getList"
        @size-change="sizeChange"
        @current-change="currentChange"
        @refresh-change="refreshChange"
      >
        <template slot-scope="scope" slot="menuBtn">
          <!-- <el-dropdown-item
            v-if="permissions.act_task_manage"
            divided
            @click.native="audit(scope.row,scope.index)">审批
          </el-dropdown-item>
          <el-dropdown-item
            v-if="permissions.act_task_manage"
            divided
            @click.native="comment(scope.row,scope.index)">批注
          </el-dropdown-item> -->
          <el-dropdown-item
            v-if="permissions.act_task_manage"
            divided
            @click.native="viewPic(scope.row, scope.index)"
            >流程图
          </el-dropdown-item>
          <el-dropdown-item
            v-if="permissions.act_task_manage"
            divided
            @click.native="checkBtn(scope.row, scope.index)"
            >查看
          </el-dropdown-item>
        </template>
      </avue-crud>
    </basic-container>
    <el-dialog :visible.sync="showTask" title="任务办理">
      <avue-form ref="form" v-model="obj" :option="formOption">
        <template slot-scope="scope" slot="menuForm">
          <el-button
            v-for="flag in flagList"
            :key="flag"
            icon="el-icon-check"
            plain
            @click="handleTask(scope.row, flag)"
            >{{ flag }}
          </el-button>
        </template>
      </avue-form>
    </el-dialog>
    <el-dialog :visible.sync="showComment" title="批注列表">
      <avue-crud :data="taskTableData" :option="taskOption" />
    </el-dialog>
    <el-dialog :visible.sync="showPicDialog" title="流程图">
      <img v-if="showPicDialog" :src="actPicUrl" width="100%" />
    </el-dialog>
    <el-dialog :visible.sync="ZbndShows" title="指标审核" width="80%" :show-close="false">
      <Zbnd :zbndData="zbndData" @ZbndChildren="ZbndChildren"></Zbnd>
    </el-dialog>
    <el-dialog :visible.sync="wbshShows" title="文本审核" width="80%" :show-close="false">
    <zhibiaoForm ref="zhibiaoRef" :zhibiaoForm='zhibiaoForm'  @zhibiaoChild='zhibiaoChild' :hetongId="hetongId"  :contractName="contractName"  :htqdorwbsh="htqdorwbsh"></zhibiaoForm>
    </el-dialog>
    <el-dialog :visible.sync="tbshShows" title="填报审核" width="80%" :show-close="false">
      <HeTongZhiBiaoTianBaoShenHeTable ref="hetongzhibiaotianbaoshenhetable" :hetongzhibiaoTable='hetongzhibiaoTable' :hetongIds="hetongId" @fnBackOldPage='fnBackOldPage'></HeTongZhiBiaoTianBaoShenHeTable>
    </el-dialog>
    <el-dialog :visible.sync="jghzShows" title="填报审核" width="80%" :show-close="false">
      <HeTongZhiBiaoTable ref="hetongzhibiaotable" :hetongzhibiaoTable='hetongzhibiaoTableHz' @fnBackOldPage="fnBackOldPageHz"></HeTongZhiBiaoTable>
    </el-dialog>
  </div>
</template>

<script>
import {
  doTask,
  fetchComment,
  fetchDetail,
  fetchList,
} from "@/api/activiti/task";
import {
  formOption,
  tableOption,
  taskOption,
} from "@/const/crud/activiti/task";
import { mapGetters } from "vuex";
import {gethtlist} from '@/api/hetongrenwu/hetongyeji/hetongnd'
import Zbnd from "@/views/hetongrenwu/hetong/hetongyeji/hetongzbsh/index"
import zhibiaoForm from '@/views/hetongrenwu/components/zhibiao-form.vue'
import HeTongZhiBiaoTianBaoShenHeTable from '@/views/hetongrenwu/components/hetongzhibiaotianbaoshenhe-table.vue'
import HeTongZhiBiaoTable from '@/views/hetongrenwu/components/hetongzhibiaohz-table.vue'
export default {
  name: "Task",
  components:{
      Zbnd,
      zhibiaoForm,
      HeTongZhiBiaoTianBaoShenHeTable,
      HeTongZhiBiaoTable
    },
  data() {
    return {
      actPicUrl: "",
      obj: {},
      flagList: [],
      ZbndShows:false,
      wbshShows:false,
      tbshShows:false,
      jghzShows:false,
      showTask: false,
      showComment: false,
      showPicDialog: false,
      tableData: [],
      zbndData:{},
      zhibiaoForm:{},
      hetongzhibiaoTable:{},
      hetongzhibiaoTableHz:{},
      contractName:"",
      htqdorwbsh:"",
      htdataList:[],
      hetongId:Number,
      taskTableData: [],
      page: {
        total: 0, // 总页数
        currentPage: 1, // 当前页数
        pageSize: 20, // 每页显示多少条
      },
      tableLoading: false,
      tableOption: tableOption,
      formOption: formOption,
      taskOption: taskOption,
    };
  },
  created() {},
  mounted: function () {},
  computed: {
    ...mapGetters(["permissions"]),
  },
  methods: {
    getList(page, params) {
      this.tableLoading = true;
      fetchList(
        Object.assign(
          {
            current: page.currentPage,
            size: page.pageSize,
          },
          params
        )
      ).then((response) => {
        this.tableData = response.data.data.records;
        this.page.total = response.data.data.total;
        this.tableLoading = false;
      });
    },
    audit: function (row) {
      fetchDetail(row.taskId).then((response) => {
        this.obj = response.data.data;
        // 根据连线判断下次的流程
        this.flagList = this.obj.flagList;
        this.showTask = true;
      });
      this.obj = row;
    },
    comment: function (row) {
      fetchComment(row.taskId).then((response) => {
        this.taskTableData = response.data.data;
      });
      this.showComment = true;
    },
    handleTask: function (row, result) {
      this.obj.taskFlag = result;
      this.$refs.form.validate((valid) => {
        if (valid) {
          doTask(this.obj).then(() => {
            this.$message({
              showClose: true,
              message: "提交成功",
              type: "success",
            });
            this.showTask = false;
            this.getList(this.page);
          });
        }
      });
    },
    viewPic: function (row) {
      this.actPicUrl = `/act/task/view/` + row.taskId;
      this.showPicDialog = true;
    },
    // 流程查看
    checkBtn(row) {
      this.hetongId=row.bussinessKey*1;
      // 合同
      if (row.processDefKey == "HE_YJHT") {
        if(row.nodeKey == "usertask4") {
          this.$emit("hetongcjC",row)
          this.ZbndShows = true;
          this.zbndData ={
            row,
            shows:false,
          }
        }else if(row.nodeKey == "usertask7"||row.nodeKey == "usertask6"){
        this.htqdorwbsh='wbsh';
          this.hetongId = row.bussinessKey;
          this.contractName = row.contractName
          this.zhibiaoForm={
              enter:2,
              disabled:true,
              hetongId:row.bussinessKey,
              streamId:row.streamId,
              taskId:row.taskId,
              formName:'wbsh'
          }
            gethtlist(row.bussinessKey).then(response => {
            this.htdataList = response.data.data
            this.htdataList.htId= response.data.data.id
              this.wbshShows = true;
            this.$nextTick(()=>{
              this.$refs.zhibiaoRef.getDataList();
              this.$refs.zhibiaoRef.saveForm(this.htdataList)
            })
          })
        }else if(row.nodeKey == "usertask9" ||row.nodeKey == "usertask10"){
          this.htqdorwbsh='htqd';
          this.hetongId = row.bussinessKey;
          this.contractName = row.contractName
          this.zhibiaoForm={
              enter:2,
              disabled:true,
              hetongId:row.bussinessKey,
              streamId:row.streamId,
              taskId:row.taskId,
              formName:'wbsh'
          }
          gethtlist(row.bussinessKey).then(response => {
            this.htdataList = response.data.data
            this.htdataList.htId= response.data.data.id
            this.wbshShows = true;
            this.$nextTick(()=>{
              this.$refs.zhibiaoRef.getDataList();
              this.$refs.zhibiaoRef.saveForm(this.htdataList)
            })
          })
        }else if(row.nodeKey == "usertask11"){
          this.tbshShows = true;
          this.hetongzhibiaoTable={
              lastPage:'tbsh',
              showSearch:true,
              pageTitle:'业绩合同',
              showBackBtn:false,
              taskId:row.taskId,
              hetongIds:row.bussinessKey
            }
        }else if(row.nodeKey == "usertask13" || row.nodeKey == "usertask14"){
          this.jghzShows = true;
          this.hetongzhibiaoTableHz={
            page:'qtjc',
            showSearch:false,
            pageTitle:'汇总查看列表',
            showBackBtn:true,
            str:1,
            hetongId:this.hetongId,
            taskId:row.taskId,
            type:'qtjc',
          }
        }
      }else if (row.processDefKey == "") {
      }
    },
    ZbndChildren(data){
      this.ZbndShows = false;
      this.getList(this.page);
    },
    zhibiaoChild(data){
      this.wbshShows = false;
      this.getList(this.page);
    },
    fnBackOldPage(){
      this.tbshShows = false;
      this.getList(this.page);
    },
    fnBackOldPageHz(data){
      this.jghzShows = false;
      this.getList(this.page);
    },
    sizeChange(pageSize) {
      this.page.pageSize = pageSize;
    },
    currentChange(current) {
      this.page.currentPage = current;
    },
    refreshChange() {
      this.getList(this.page);
    },
  },
};
</script>

<style lang="scss" scoped>
</style>

